Django框架,我们只需要关心二点:
1.根据用户访问不同的路径执行不同的函数
2.从HTML读取出内容,并且完成字符串的替换
而socket通信不需要我们自己写;
新建Django项目 命令行创建: django-admin startproject mysite pycharm创建: 1. File --> New project --> 左侧选Django --> 右侧填第二个项目路径,并且勾选python.exe
设置Django项目:
1. settings.py 1. 配置HTML文件存放的位置(Templates)2. 配置静态文件(CSS/JS/图片)存放的位置
3. 注释掉setting.py中 带有 csrf 的那一行。
Django项目的启动:
1. 命令行启动 在项目的根目录下(也就是有manage.py的那个目录),运行: python3 manage.py runserver IP:端口--> 在指定的IP和端口启动 python3 manage.py runserver 端口 --> 在指定的端口启动 python3 manage.py runserver --> 默认在本机的8000端口启动2.PyCharm启动
点绿色的小三角,直接可以启动Django项目(前提是小三角左边是你的Django项目名)
MVC是软件工程中的一种软件架构模式,把软件系统分为三个基本部分:模型(Model)、视图(View)和控制器(Controller),具有耦合性低、重用性高、生命周期成本低等优点;
MVC中的控制器可以看做是Django中的urls.py和views.py(不同路径对应的不同的函数,并且执行函数);视图可以看做是templates(存放html文件的);模型相当于models.py(在数据库中生产表的)
而Django框架的设计模式借鉴了MVC框架的思想,也是分成三部分,来降低各个部分之间的耦合性。Django框架的不同之处在于它拆分的三部分为:Model(模型)、Template(模板)和View(视图),也就是MTV框架。
如下图:
Django中的APP:
什么是APP?以及为什么要用APP?
project --> 项目 (学校)
APP --> 应用 (Linux学院/Python学院/大数据学院/Java学院)用APP就是为了方便 我们在一个大的Django项目中,管理实现不同的业务功能.创建app
python3 manage.py startapp my_app
Django模板系统()
模板系统本质上就是(在html文件中进行字符串替换);
语法:
{ { 变量 }} ;{% %}则是逻辑相关用的;
1. 变量相关: {
{ name }},{ {name|length}},{ {name|default:"默认值"}}在Django的模板语言中,通过使用 过滤器 来改变变量的显示。
过滤器的语法: { { value|filter_name:参数 }}
使用管道符"|"来表示过滤器(filters)。
下面是内置的过滤器:
1.default :
如果一个变量是false或者为空,使用给定的默认值。 否则,使用变量的值。
2.length:
返回值的长度,作用于字符串和列表。
3.filesizeformat:
将值格式化为一个 “人类可读的” 文件尺寸 (例如 '13 KB'
, '4.1 MB'
, '102 bytes'
, 等等)
4.slice
切片
date
日期格式化
{#{ { JS_html|safe }}#}{ { JS_html }}{ { name }}{
{ now|date:"Y-m-d H:i:s" }}{
{ text }}{
{ text|truncatechars:18 }}文件大小:{
{ size|filesizeformat }}
5. safe --> XSS攻击(跨站脚本攻击)
Django的模板中会对HTML标签和JS等语法标签进行自动转义,原因显而易见,这样是为了安全。但是有的时候我们可能不希望这些HTML元素被转义,用户输入的信息如果是js的话,进行自动的转义后网站有可能会受到攻击。因此把js的语法标签 转为字符串了;如果告诉Django这个代码是安全的,就会自动转义为相应内容;但是不告诉,则会转变为字符串;
value = "点我"
{ { value|safe}}
6. truncatechars:20 --> 截取字符,超过的用...表示
如果字符串字符多于指定的字符数量,那么会被截断。截断的字符串将以可翻译的省略号序列(“...”)结尾。
参数:截断的字符数
{ { value|truncatechars:9}}
自定义的filter
1. 定义阶段
1. 在app下面新建一个python的包:templatetags 2. 在上面的Python包中新建一个Python文件,名字随意 3. 在上述python文件中: from django import template # 生成一个注册用的实例 register = template.Library() # 定义并注册一个自定义的filter函数 @register.filter(name='addsb') def add_sb(arg): return "{} sb".format(arg)from django import templateregister = template.Library()# 自定义filter函数方法# 告诉Django的模板语言我现在有一个自定义的filter方法名@register.filter(name="addstr")def add_str(arg,arg2): #自定义的filter 函数的 方法 只能有 两个参数; """ :param arg: 第一个参数永远是管道符(|)前面的变量 :param agr2: 方法:变量;冒号后面的变量 :return: """ return "{},{}".format(arg,arg2)
自定的filter函数只能传入一个变量(就是冒号后面的变量) ;
而simple_tage 可以传入多个值;inclusion_tag可以返回一段html的代码(比如返回url标签)
如下:
#simple_tag 指定的方法可以传入多个值@register.simple_tag(name="add_sum")def add_sum(arg,arg1,arg2,arg3): return "{}+{}+{}+{}".format(arg,arg1,arg2,arg3)# inclusion_tag 自动的帮 你把函数的返回值 替换到你指定的html里面, # 然后把结果最后的返回给调用函数的地方;@register.inclusion_tag("incolusion_demo.html")def show_results(n): n=1 if n<1 else int(n) data = ["第{}次".format(i) for i in range(1,n+1)] return {"data":data}
2. 调用阶段:
1. 在Django的模板文件中,导入刚才新建的python文件 {% load py文件名 %} 2. 按照filter的语法调用 { { name|addsb }}{#在调用自己写的方法的时候需要用load调用app里面的templatetags里面的文件#}{% load myfilter %}{ { name|addstr:"张映雪" }}{% load my_simple_tag %}{% add_sum "张映雪" "张映雪" "张映雪" "张映雪" %}{% show_results 5 %}
2. 逻辑相关:
1. if判断 {% if a > b %} {% endif %} {% if a > b %} {% else %} {% endif %} {% if a > b %} {% elif %} {% else %} {% endif %} 2. for循环 1. for循环的基本用法: {% for i in name_list %} { { i }} {% endfor %} {% for i in name_list %} { { i }} {% empty %} #如果没有数据 则会执行empty后面的语句 空空如也 {% endfor %} 2. for循环可用的属性: forloop.counter (从1开始计数) forloop.counter0(从0开始计数) forloop.revcounter(从1反向计数) forloop.revcounter0(从0反向计数) forloop.first 当前循环是不是第一次循环 forloop.last 当前循环是不是最后一次循环这两个返回pool值
forloop.parentloop --> 两层for循环,内层循环引用外层循环模板中支持的写法:
{# 取l中的第一个参数 #}{ { l.0 }}{# 取字典中key的值 #}{ { d.name }}{# 取对象的name属性 #}{ { person_list.0.name }}{# .操作只能调用不带参数的方法,并且方法后面不需要() #}{ { person_list.0.dream }}
1. 母版和继承
1. 为什么要有模板和继承: 把多个页面公用的部分提取出来,放在一个 母版 里面。 其他的页面只需要 继承 母版就可以了。这样方便; 2. 具体使用的步骤: 1. 把公用的HTML部分提取出来,放到base.html文件中 2. 在base.html中,通过定义block,把每个页面不同的部分区分出来 3. 在具体的页面中,先继承母版{% extends "base.html(母版的html)" %} 4. 然后block名去指定替换母版中相应的位置母版(框架):
{# 下面是用来替换的 #} {% block page_content %} {% endblock %}
继承母版的新的html
{#继承母版#}{% extends "base.html" %}{#把自己的页面内容 放入到母版里面的blck的位置里面#}{% block page_content %} {# 里面就是所替换的内容#}{% endblock %}{% block book_active %}active{% endblock %}
3. 使用母版和继承的注意事项:
1. {% extends 'base.html' %} --> 母版文件:base.html要加引号 2. {% extends 'base.html' %}必须放在子页面的第一行!!! 3. 可以在base.html中定义很多block,通常我们会额外定义page-css和page-js两个块{% block page_css %}{% endblock %}{% block page_js %}{% endblock %}
4. view.py相应的函数中返回的是对应的子页面文件 不是 base.html
组件:
可以将常用的页面内容如导航条,页尾信息等组件保存在单独的文件中,然后在需要使用的地方按如下语法导入即可。
{% include 'navbar.html' %}
静态文件相关的
{% load static %}
某个文件多处被用到可以存为一个变量
{% load static %}{% static "images/hi.jpg" as myphoto %}
{% load static %}